import React,{useEffect} from 'react';
import {lazyImg} from "../../assets/js/utils";

function hoc(WitchComponent) {
    function HocComponent(props) {
        //点击跳转页面
        function goPages(url){
            let strUrl = "^(://)" +
                "?(([0-9a-z_!~*'().&=+$%-]+: )?[0-9a-z_!~*'().&=+$%-]+@)?" +//ftp的user@+
                "(([0-9]{1,3}.){3}[0-9]{1,3}" +// IP形式的URL- 199.194.52.184 +
                "|" +// 允许IP和DOMAIN（域名） +
                "([0-9a-z_!~*'()-]+.)*" +// 域名- www. +
                "([0-9a-z][0-9a-z-]{0,61})?[0-9a-z]." +// 二级域名 +
                "[a-z]{0,6})" +// first level domain- .com or .museum +
                "(:[0-9]{1,4})?" +// 端口- :80 +
                "((/?)|"  +// a slash isn't required if there is no file name +
                "(/[0-9a-z_!~*'().;?:@&=+$,%#-]+)+/?)$";
            let reg = new RegExp(strUrl);
            if (!reg.test(url)){
                window.open(url)
            }else {
                props.history.push(window.base.config.path+url)
            }
        }
        useEffect(()=>{
            lazyImg()
            return

        })
        let newProps={
            goPages:goPages
        }
        return(
            <WitchComponent {...props} {...newProps}></WitchComponent>
        )
    }
    return HocComponent
}
export default hoc